# **NVM Express Technical Errata**

| Errata ID           | 003             |
|---------------------|-----------------|
| Affected Spec Ver.  | NVM Express 1.0 |
| Corrected Spec Ver. |                 |

#### Submission info

| Name           | Company | Date     |
|----------------|---------|----------|
| Mike Shapiro   | DSSD    | 3/3/2011 |
| Matthew Wilcox | Intel   | 3/8/2011 |
| Amber Huffman  | Intel   | 3/3/2011 |

| This erratum enables future implementations to support a dynamic doorbell size. This capability enables more efficient software emulation of an NVM Express controller. For example, a software thread monitoring doorbell notifications may observe a cacheline accessed by a spin loop or utilize the monitor/mwait CPU instructions. This capability is enabled in a way that does not impact any hardware implementations. |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                |

## Modify section 3.1 as shown:

The following table describes the register map for the controller.

| Start                    | End                      | Symbol     | Description                              |
|--------------------------|--------------------------|------------|------------------------------------------|
| 00h                      | 07h                      | CAP        | Controller Capabilities                  |
| 08h                      | 0Bh                      | VS         | Version                                  |
| 0Ch                      | 0Fh                      | INTMS      | Interrupt Mask Set                       |
| 10h                      | 13h                      | INTMC      | Interrupt Mask Clear                     |
| 14h                      | 1Bh                      | CC         | Controller Configuration                 |
| 1Ch                      | 1Fh                      | CSTS       | Controller Status                        |
| 20h                      | 23h                      | Reserved   | Reserved                                 |
| 24h                      | 27h                      | AQA        | Admin Queue Attributes                   |
| 28h                      | 2Fh                      | ASQ        | Admin Submission Queue Base Address      |
| 30h                      | 37h                      | ACQ        | Admin Completion Queue Base Address      |
| 38h                      | EFFh                     | Reserved   | Reserved                                 |
| F00h                     | FFFh                     | Reserved   | Command Set Specific                     |
| 1000h                    | 1003h                    | SQ0TDBL    | Submission Queue 0 Tail Doorbell (Admin) |
| <del>1004h</del>         | <del>1007h</del>         |            |                                          |
| 1000h + (1 *             | 1003h + (1 *             | CQ0HDBL    | Completion Queue 0 Head Doorbell (Admin) |
| (4 << CAP.DSTRD))        | (4 << CAP.DSTRD))        |            |                                          |
| <del>1008h</del>         | <del>100Bh</del>         |            |                                          |
| 1000h + (2 *             | 1003h + (2 *             | SQ1TDBL    | Submission Queue 1 Tail Doorbell         |
| (4 << CAP.DSTRD))        | (4 << CAP.DSTRD))        |            |                                          |
| <del>100Ch</del>         | <del>100Fh</del>         |            |                                          |
| 1000h + (3 *             | 1003h + (3 *             | CQ1HDBL    | Completion Queue 1 Head Doorbell         |
| (4 << CAP.DSTRD))        | (4 << CAP.DSTRD))        |            |                                          |
| <del>1010h</del>         | <del>1013h</del>         |            |                                          |
| 1000h + (4 *             | 1003h + (4 *             | SQ2TDBL    | Submission Queue 2 Tail Doorbell         |
| (4 << CAP.DSTRD))        | (4 << CAP.DSTRD))        |            |                                          |
| <del>1014h</del>         | <del>1017h</del>         | 00011001   |                                          |
| 1000h + (5 *             | 1003h + (5 *             | CQ2HDBL    | Completion Queue 2 Head Doorbell         |
| (4 << CAP.DSTRD))        | (4 << CAP.DSTRD))        |            |                                          |
|                          | ***                      |            |                                          |
| 1000h +                  | 1003h +                  |            |                                          |
| (2y * (4 <<              | (2y * (4 <<              | SQyTDBL    | Submission Quaya y Tail Doorball         |
| CAP.DSTRD))              | CAP.DSTRD))              | SQYIDBL    | Submission Queue y Tail Doorbell         |
| <del>(8*y)</del>         | <del>(8*y)</del>         |            |                                          |
| <del>1004h + (8*y)</del> | <del>1007h + (8*y)</del> |            |                                          |
| 1000h +                  | 1003h +                  | CQyHDBL    | Completion Queue y Head Doorbell         |
| ((2y + 1) * (4 <<        | ((2y + 1) * (4 <<        | O Gy, IDDL | Completion added y fload Doorbon         |
| CAP.DSTRD))              | CAP.DSTRD))              |            |                                          |
|                          |                          |            | Vendor Specific (Optional)               |

### Modify the definition of the Controller Capabilities register in section 3.1.1 as shown:

| 36 <del>:32</del> | RO | 0 <del>h</del> | Reserved                                                                                                                                                                                                                                                                                                                                                                                        |
|-------------------|----|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 35:32             | RO | Impl<br>Spec   | <b>Doorbell Stride (DSTRD):</b> Each Submission Queue and Completion Queue Doorbell register is 32-bits in size. This register indicates the stride between doorbell registers. The stride is specified as (2 ^ (2 + DSTRD)) in bytes. A value of 0h indicates a stride of 4 bytes, where the doorbell registers are packed without reserved space between each register. Refer to section 8.6. |

| Modify the heading of section 3.1.10 as shown:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3.1.10 Offset (1000h + ((2y) * (4 << CAP.DSTRD)) 8*y): SQyTDBL - Submission Queue y Tail Doorbell                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Modify the heading of section 3.1.11 as shown:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 3.1.11 Offset (1000h + ((2y + 1) * (4 << CAP.DSTRD)) 1004h + 8*y): CQyHDBL - Completion Queue y Head Doorbell                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Add section 8.6 to the specification, as shown:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 8.6 Doorbell Stride for Software Emulation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| The doorbell stride, specified in CAP.DSTRD, may be used to separate doorbells by a number of bytes in memory space. The doorbell stride is a number of bytes equal to (2 ^ (2 + CAP.DSTRD)). This is useful in software emulation of an NVM Express controller. In this case, a software thread is monitoring doorbell notifications. The software thread may be made more efficient by monitoring one doorbell per discrete cacheline or utilize the monitor/mwait CPU instructions. For hardware implementations of NVM Express, the expected doorbell stride value is 0h. |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

### Disposition log

| 3/3/2011<br>3/8/2011<br>3/13/2011<br>3/17/2011<br>3/21/2011 | Erratum captured. Updated formulas in erratum, added introductory section. Updated formulas in erratum. Added sentence to section 8.6. Updates to formulas based on reflector feedback. |
|-------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                             | Updates to formulas based on reflector feedback.                                                                                                                                        |
| 4/26/2011                                                   | Erratum ratified.                                                                                                                                                                       |

Technical input submitted to the NVMHCI Workgroup is subject to the terms of the NVMHCI Contributor's agreement.